package com.tegtech.module.auth.domain;

import java.io.Serializable;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import javax.validation.constraints.Email;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.Size;

import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableLogic;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonProperty;

import cn.afterturn.easypoi.excel.annotation.Excel;
import cn.afterturn.easypoi.excel.annotation.ExcelEntity;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;

/**
 * 用户对象 sys_user
 * 
 * @author Jun
 */

@Data
@NoArgsConstructor
@Accessors(chain = true)
@TableName("sys_user")
public class SysUser implements Serializable {
	
	private static final long serialVersionUID = 1L;

	/** 用户ID */
	@Excel(name = "用户编号", type = 10)
	@TableId(value = "user_id", type = IdType.AUTO)
	private Long userId;

	/** 部门ID */
	@Excel(name = "部门编号", type = 10)
	private Long deptId;

	/** 用户账号 */
	@NotBlank(message = "用户账号不能为空")
	@Size(min = 0, max = 30, message = "用户账号长度不能超过30个字符")
	@Excel(name = "登录名称", width = 15)
	private String userName;

	/** 用户昵称 */
	@Size(min = 0, max = 30, message = "用户昵称长度不能超过30个字符")
	@Excel(name = "用户名称", width = 20)
	private String nickName;

	/** 用户邮箱 */
	@Email(message = "邮箱格式不正确")
	@Size(min = 0, max = 50, message = "邮箱长度不能超过50个字符")
	@Excel(name = "用户邮箱", width = 30)
	private String email;

	/** 手机号码 */
	@Size(min = 0, max = 11, message = "手机号码长度不能超过11个字符")
	@Excel(name = "手机号码", width = 20)
	private String phonenumber;

	/** 用户性别 */
	@Excel(name = "用户性别", replace = {"男_0", "女_1", "未知_2"})
	private String sex;

	/** 用户头像 */
	private String avatar;

	/** 密码 */
	private String password;

	/** 盐加密 */
	private String salt;

	/** 帐号状态（0正常 1停用） */
	@Excel(name = "帐号状态", replace = {"正常_0", "停用_1"})
	private String status;

	/** 删除标志（0代表存在 2代表删除） */
	@TableLogic
	private String delFlag;

	/** 最后登录IP */
	@Excel(name = "最后登陆IP", width = 15)
	private String loginIp;

	/** 最后登录时间 */
	@Excel(name = "最后登陆时间", width = 30, format = "yyyy-MM-dd HH:mm:ss")
	private Date loginDate;

	/** 创建者 */
	@TableField(fill = FieldFill.INSERT)
	private String createBy;

	/** 创建时间 */
	@TableField(fill = FieldFill.INSERT)
	@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
	private Date createTime;

	/** 更新者 */
	@TableField(fill = FieldFill.INSERT_UPDATE)
	private String updateBy;

	/** 更新时间 */
	@TableField(fill = FieldFill.INSERT_UPDATE)
	@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
	private Date updateTime;

	/** 备注 */
	private String remark;

	/**
	 * 请求参数
	 */
	@TableField(exist = false)
	private Map<String, Object> params = new HashMap<>();

	/** 部门对象 */
	@ExcelEntity
	@TableField(exist = false)
	private SysDept dept;

	/** 角色对象 */
	@TableField(exist = false)
	private List<SysRole> roles;

	/** 角色组 */
	@TableField(exist = false)
	private Long[] roleIds;

	/** 岗位组 */
	@TableField(exist = false)
	private Long[] postIds;

	public SysUser(Long userId) {
		this.userId = userId;
	}

	public boolean isAdmin() {
		return isAdmin(this.userId);
	}

	public static boolean isAdmin(Long userId) {
		return userId != null && 1L == userId;
	}
	
	@JsonIgnore
	@JsonProperty
    public String getPassword() {
        return password;
    }

}
